//有一份由 n 个问题组成的调查问卷，每个问题的答案要么是 0（no，否），要么是 1（yes，是）。 
//
// 这份调查问卷被分发给 m 名学生和 m 名导师，学生和导师的编号都是从 0 到 m - 1 。学生的答案用一个二维整数数组 students 表示，其中 
//students[i] 是一个整数数组，包含第 i 名学生对调查问卷给出的答案（下标从 0 开始）。导师的答案用一个二维整数数组 mentors 表示，其中 m
//entors[j] 是一个整数数组，包含第 j 名导师对调查问卷给出的答案（下标从 0 开始）。 
//
// 每个学生都会被分配给 一名 导师，而每位导师也会分配到 一名 学生。配对的学生与导师之间的兼容性评分等于学生和导师答案相同的次数。 
//
// 
// 例如，学生答案为[1, 0, 1] 而导师答案为 [0, 0, 1] ，那么他们的兼容性评分为 2 ，因为只有第二个和第三个答案相同。 
// 
//
// 请你找出最优的学生与导师的配对方案，以 最大程度上 提高 兼容性评分和 。 
//
// 给你 students 和 mentors ，返回可以得到的 最大兼容性评分和 。 
//
// 
//
// 示例 1： 
//
// 输入：students = [[1,1,0],[1,0,1],[0,0,1]], mentors = [[1,0,0],[0,0,1],[1,1,0]]
//输出：8
//解释：按下述方式分配学生和导师：
//- 学生 0 分配给导师 2 ，兼容性评分为 3 。
//- 学生 1 分配给导师 0 ，兼容性评分为 2 。
//- 学生 2 分配给导师 1 ，兼容性评分为 3 。
//最大兼容性评分和为 3 + 2 + 3 = 8 。 
//
// 示例 2： 
//
// 输入：students = [[0,0],[0,0],[0,0]], mentors = [[1,1],[1,1],[1,1]]
//输出：0
//解释：任意学生与导师配对的兼容性评分都是 0 。
// 
//
// 
//
// 提示： 
//
// 
// m == students.length == mentors.length 
// n == students[i].length == mentors[j].length 
// 1 <= m, n <= 8 
// students[i][k] 为 0 或 1 
// mentors[j][k] 为 0 或 1 
// 
// Related Topics 位运算 数组 动态规划 回溯 状态压缩 
// 👍 12 👎 0

  
package com.zwy.leetCode.editor.cn;

import java.util.LinkedList;
import java.util.List;

public class MaximumCompatibilityScoreSum{
    public static void main(String[] args) {
        Solution solution = new MaximumCompatibilityScoreSum().new Solution();
        int [][]students = {{0,0},{0,0},{0,0}};
        int [][]mentors = {{1,1},{1,1},{1,1}};
        solution.maxCompatibilitySum(students,mentors);
      }
      //leetcode submit region begin(Prohibit modification and deletion)
class Solution {
        int max=0;
    public int maxCompatibilitySum(int[][] students, int[][] mentors) {
        LinkedList<int []>list=new LinkedList<>();
        back(list,students.length,students,mentors);
        return max;
    }
    public void back(LinkedList<int []>list,int len,int [][]student,int [][]mentors){
        if(list.size()==len){
            int result=0;
            for (int i = 0; i < mentors.length; i++) {
                for (int j = 0; j < mentors[0].length; j++) {
                    if(mentors[i][j]==list.get(i)[j])result++;
                    max=Math.max(max,result);
                }
            }
            return;
        }
        for (int i = 0; i < len; i++) {
            if(list.contains(student[i]))continue;
            list.add(student[i]);
            back(list,len,student,mentors);
            list.removeLast();
        }
    }
}
//leetcode submit region end(Prohibit modification and deletion)

}